package com.jvyou.app.ds.domain.entity;

import com.baomidou.mybatisplus.annotation.*;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.io.Serializable;
import java.time.LocalDateTime;

/**
 * 驾校课时主表(Lesson)表实体类
 *
 * @author 橘柚
 * @since 2025-04-11 13:19:59
 */
@Data
@AllArgsConstructor
@NoArgsConstructor
@TableName("ds_lesson")
public class Lesson implements Serializable {
    private static final long serialVersionUID = 1L;
    /**
     * ID主键
     */
    @TableId(type = IdType.ASSIGN_ID)
    private Long id;
    /**
     * 教练ID
     */
    @TableField("coach_id")
    private Long coachId;

    /**
     * 车辆ID
     */
    @TableField("plate_number")
    private String plateNumber;

    /**
     * 驾照类型
     */
    @TableField("license_type_id")
    private Long licenseTypeId;

    /**
     * 课程类型(1-科目一,2-科目二,3-科目三,4-科目四)
     */
    @TableField("course_type_id")
    private Long courseTypeId;

    /**
     * 课时开始时间
     */
    @TableField("start_time")
    private LocalDateTime startTime;

    /**
     * 课时结束时间
     */
    @TableField("end_time")
    private LocalDateTime endTime;

    /**
     * 预约状态(1可预约，2预约上限，3禁止预约)
     */
    @TableField("status")
    private String status;

    /**
     * 课程签到口令
     */
    @TableField("password")
    private String password;

    /**
     * 最大学员数量
     */
    @TableField("max_students")
    private Integer maxStudents;

    /**
     * 当前学员数量
     */
    @TableField("current_students")
    private Integer currentStudents;

    /**
     * 备注
     */
    @TableField("remark")
    private String remark;

    /**
     * 逻辑删除标志（0-未删除，1-已删除）
     */
    @TableField("is_deleted")
    private Integer isDeleted;

    /**
     * 乐观锁版本号
     */
    @TableField("version")
    private Integer version;

    /**
     * 创建人ID
     */
    @TableField(value = "created_by", fill = FieldFill.INSERT)
    private String createdBy;

    /**
     * 创建时间
     */
    @TableField(value = "created_at", fill = FieldFill.INSERT)
    private LocalDateTime createdAt;

    /**
     * 更新人ID
     */
    @TableField(value = "updated_by", fill = FieldFill.INSERT_UPDATE)
    private String updatedBy;

    /**
     * 更新时间
     */
    @TableField(value = "updated_at", fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updatedAt;

    /**
     * 教练姓名
     */
    @TableField(exist = false)
    private String coachName;


    /**
     * 驾照类型代码(如C1、C2、A1等)
     */
    @TableField(exist = false)
    private String licenseTypeCode;

    /**
     * 驾照类型名称
     */
    @TableField(exist = false)
    private String licenseTypeName;

    /**
     * 驾照类型名称
     */
    @TableField(exist = false)
    private String licenseTypColor;

    /**
     * 科目名称
     */
    @TableField(exist = false)
    private String courseSubjectName;

    /**
     * 科目名称
     */
    @TableField(exist = false)
    private String courseSubjectColor;

    /**
     * 教练头像
     */
    @TableField(exist = false)
    private Long coachAvatar;

    /**
     * 签到状态
     */
    @TableField(exist = false)
    private String signInStatus;
}
